<?php

require_once(dirname(__FILE__) . "/../../config.php");
ini_set('date.timezone', 'Asia/Shanghai');
//error_reporting(E_ERROR);
require_once "../lib/WxPay.Api.php";
require_once "WxPay.JsApiPay.php";
require_once 'log.php';

session_start();


$mid = $cfg_ml->M_ID;


//注意，微信里边不能GET传参订单号，只能从会员ID去数据库里边读取 
$arr = $dsql->GetOne("select * from #@__member_operation where mid = '" . $mid . "' order by aid desc ");


if (empty($arr['buyid']))
{
    die("订单号" . $arr['buyid'] . "有误，请重新操作！");
}
else
{
    $ddh = $arr['buyid'];
}


//初始化日志
$logHandler = new CLogFileHandler("../logs/" . date('Y-m-d') . '.log');
$log        = Log::Init($logHandler, 15);

//打印输出数组信息
function printf_info($data)
{
    foreach ($data as $key => $value)
    {
        echo "<font color='#00ff55;'>$key</font> : $value <br/>";
    }
}


//①、获取用户openid
$tools = new JsApiPay();


$openId = $tools->GetOpenid();


//②、统一下单
$input = new WxPayUnifiedOrder();
$input->SetBody($arr['pname']);
$input->SetAttach($arr['pname']);
$input->SetOut_trade_no($ddh);
$jiage = $arr['money'] * 100;
if ($mid == '534')
{ //九戒织梦
    $jiage = 100;
}


$input->SetTotal_fee($jiage);
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag("在线订单");
$input->SetNotify_url($cfg_basehost . "/user/weixinpay/example/notify.php");
$input->SetTrade_type("JSAPI");
$input->SetOpenid($openId);
$order = WxPayApi::unifiedOrder($input);
//echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>';
//printf_info($order);
$jsApiParameters = $tools->GetJsApiParameters($order);

//获取共享收货地址js函数参数
$editAddress = $tools->GetEditAddressParameters();

//③、在支持成功回调通知中处理成功之后的事宜，见 notify.php
/**
 * 注意：
 * 1、当你的回调地址不可访问的时候，回调通知会失败，可以通过查询订单来确认支付是否成功
 * 2、jsapi支付时需要填入用户openid，WxPay.JsApiPay.php中有获取openid流程 （文档可以参考微信公众平台“网页授权接口”，
 * 参考http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html）
 */


?>

<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
    <meta name="viewport" content="width=device-width, initial-scale=1"/>
    <title>微信支付-支付</title>
    <script type="text/javascript">
        //供使用者调用
        function trim(s) {
            return trimRight(trimLeft(s));
        }

        //去掉左边的空白
        function trimLeft(s) {
            if (s == null) {
                return "";
            }
            var whitespace = new String(" \t\n\r");
            var str = new String(s);
            if (whitespace.indexOf(str.charAt(0)) != -1) {
                var j = 0, i = str.length;
                while (j < i && whitespace.indexOf(str.charAt(j)) != -1) {
                    j++;
                }
                str = str.substring(j, i);
            }
            return str;
        }

        //去掉右边的空白 www.2cto.com
        function trimRight(s) {
            if (s == null) return "";
            var whitespace = new String(" \t\n\r");
            var str = new String(s);
            if (whitespace.indexOf(str.charAt(str.length - 1)) != -1) {
                var i = str.length - 1;
                while (i >= 0 && whitespace.indexOf(str.charAt(i)) != -1) {
                    i--;
                }
                str = str.substring(0, i + 1);
            }
            return str;
        }

        //调用微信JS api 支付
        function jsApiCall() {
            WeixinJSBridge.invoke(
                'getBrandWCPayRequest',
                <?php echo $jsApiParameters; ?>,
                function (res) {
                    WeixinJSBridge.log(res.err_msg);
                    var Cts = trim(res.err_msg);
                    if (Cts.indexOf(":ok") > 0) {
                        alert("恭喜，付款成功！");
                        window.location.href = '/web_user/';
                    } else {
                        alert(res.err_msg);
                    }

                    //alert(res.err_code+res.err_desc+res.err_msg);
                }
            );
        }

        function callpay() {
            if (typeof WeixinJSBridge == "undefined") {
                if (document.addEventListener) {
                    document.addEventListener('WeixinJSBridgeReady', jsApiCall, false);
                } else if (document.attachEvent) {
                    document.attachEvent('WeixinJSBridgeReady', jsApiCall);
                    document.attachEvent('onWeixinJSBridgeReady', jsApiCall);
                }
            } else {
                jsApiCall();
            }
        }
    </script>
    <script type="text/javascript">
        //获取共享地址
        function editAddress() {
            WeixinJSBridge.invoke(
                'editAddress',
                <?php echo $editAddress; ?>,
                function (res) {
                    var value1 = res.proviceFirstStageName;
                    var value2 = res.addressCitySecondStageName;
                    var value3 = res.addressCountiesThirdStageName;
                    var value4 = res.addressDetailInfo;
                    var tel = res.telNumber;

                    alert(value1 + '|' + value2 + '|' + value3 + '|' + value4 + '|' + ":" + tel);
                }
            );
        }

        window.onload = function () {
            /*
            if (typeof WeixinJSBridge == "undefined"){
                if( document.addEventListener ){
                    document.addEventListener('WeixinJSBridgeReady', editAddress, false);
                }else if (document.attachEvent){
                    document.attachEvent('WeixinJSBridgeReady', editAddress);
                    document.attachEvent('onWeixinJSBridgeReady', editAddress);
                }
            }else{
                editAddress();
            }
            */
        };

    </script>
</head>
<body style="text-align:center;">
<br/>
<font color="#9ACD32"><b><?php echo $arr['pname']; ?>
        <span style="color:#f00;font-size:50px"><?php echo $arr['money']; ?>元 </span></b></font><br/><br/>
<div align="center">
    <button style="width:210px; height:50px; border-radius: 15px;background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer;  color:white;  font-size:16px;" type="button" onClick="callpay()">
        立即支付
    </button>
</div>
</body>
</html>